**Rust RISC-V ISA Simulator with Qt GUI**

**Darshan H Sonecha**

**Introduction**

This document represents the design and implementation of RISC-V ISA simulator, intended to be geared to suit various classes of processor SHAKTI. The simulator is to allow for development and test of simple programs to compilers to operating systems. There are various kinds of simulations in the real-world - **architectural level simulation**, **direct execution**, **threaded code**, and **instruction set simulators 1,[[1]](#footnote-1)**. ISS is also referred to as "complete system instruction set simulator"**1**.

We are to implement the ISS – behavioral simulation model. The implementation of simulator should have the following characteristics - **accuracy**, **speed[[2]](#footnote-2), reproducibility** and **options** yielding flexibility – for example, one of the option family could be for the performance of the program being executed. **Extensibility** and **Statistics** are two additional features/characteristics to be built upon as needed. Few of these characteristics would be traded off amongst or against each other.

The implementation is to be in Rust. The goal of this simulator is to allow for the **execution of the program**, **operation** **systems**, and **simulator test code**

The first version of the implementation would be for RV32G ISA, additional extensions and expansions to follow later. The ISA is the interface between hardware and software and is a major portion of what makes up an architecture2. In following sections, we will discuss **1)** Block Level Architecture, **2)** Data Structures, Software Modules, Software Processes **3)** Program Flow/Execution Model, **4)** Data Flow Model, **5)** Tests and **6)** Conclusion. We will discuss various implementation details including optimization details that improve in the performance of the simulator.

As in with other simulation tools but with the constraint that this ISS is more behavioral modeling, we may explore design space exploration possibilities - more from the perspective of supporting heterogeneous and homogeneous multicore architectures2, without timing constraints. As well there will be traces that will be generated to study the simulation flow and aid in debugging of the logic. There are existing simulator architectures for exploration of architectural and microarchitectural features such as Sniper. As well there are reference RISC-V ISA functional simulator such as Spike.

**Block Level Architect**

![https://documents.lucidchart.com/documents/661ac21b-dee9-4fae-81c0-4d3069f696ae/pages/0_0?a=609&x=-51&y=122&w=1417&h=396&store=1&accept=image%2F*&auth=LCA%201b9eff29dc666add0de12484db9f77d879bb13f0-ts%3D1558381763](data:image/png;base64,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)

1. **(b)**

A complete ISA implements the management of processor resource, memory resource, I/O resource and interrupts4.

**Data Structures, Software Modules, Software Processes**

**DS**

**CPUState, Memory, Instruction**

**SM**

**SP**

**Program Flow/Execution Model**

**Data Flow Model**

**Tests**

**Conclusion**

There are various tools envisioned to be used - Microsoft Word, Emacs, IntelliJ IDE, GCC – RISC-V Cross Compiler/GNU Tools Chain, Bluespec System Verilog Simulation Model – Bluespec Inc. and RISC-V Torture, CSMIT, AAPG.

Data Structures:

RV32I\_Opcode\_Map {

u32 U\_lui; // imm[31:12] | rd | 0110111

u32 U\_auipc; // imm[31:12] | rd | 0010111

u32 J\_jal; // imm[20|10:1|11|19:12] | rd | 1101111

u32 I\_jalr; // imm[11:0] | rs1 | 000 | rd | 1100111

u32 B\_beq; // imm[12|10:5] | rs2 | rs1 | 000 | imm[4:1|11] | 1100011

u32 B\_bne; // imm[12|10:5] | rs2 | rs1 | 001 | imm[4:1|11] | 1100011

u32 B\_blt; // imm[12|10:5] | rs2 | rs1 | 100 | imm[4:1|11] | 1100011

u32 B\_bge; // imm[12|10:5] | rs2 | rs1 | 101 | imm[4:1|11] | 1100011

u32 B\_bltu; // imm[12|10:5] | rs2 | rs1 | 110 | imm[4:1|11] | 1100011

u32 B\_bgeu; // imm[12|10:5] | rs2 | rs1 | 111 | imm[4:1|11] | 1100011

u32 I\_1b; // imm[11:0] | rs1 | 000 | rd | 0000011

u32 I\_1h; // imm[11:0]. | rs1 | 001 | rd | 0000011

u32 I\_1w; // imm[11:0] | rs1 | 010 | rd | 0000011

u32 I\_1lu; // imm[11:0] | rs1 | 100 | rd | 0000011

u32 I\_1hu; // imm[11:0] | rs1 | 101 | rd | 0000011

u32 S\_sb; // imm[11:5] | rs2 | rs1 | 000 | imm[4:0] | 0100011

u32 S\_sh; // imm[11:5] | rs2 | rs1 | 001 | imm[4:0] | 0100011

u32 S\_sw; // imm[11:5] | rs2 | rs1 | 010 | imm[4:0] | 0100011

u32 I\_addi; // imm[11:0] | rs1 | 000 | rd | 0010011

u32 I\_slti; // imm[11:0] | rs1 | 010 | rd | 0010011

u32 I\_sltiu; // imm[11:0] | rs1 | 011 | rd | 0010011

u32 I\_xori; // imm[11:0] | rs1 | 100 | rd | 0010011

u32 I\_ori; // imm[11:0] | rs1 | 110 | rd | 0010011

u32 I\_andi; // imm[11:0] | rs1 | 111 | rd | 0010011

u32 I\_slli; // 0000000 | shamt | rs1 | 001 | rd | 0010011

u32 I\_srli; // 0000000 | shamt | rs1 | 101 | rd | 0010011

u32 I\_srai; // 0100000 | shamt | rs1 | 101 | rd | 0010011

u32 R\_add; // 0000000 | rs2 | rs1 | 000 | rd | 0110011

u32 R\_sub; // 0100000 | rs2 | rs1 | 000 | rd | 0110011

u32 R\_sll // 0000000 | rs2 | rs1 | 001 | rd | 0110011

u32 R\_slt // 0000000 | rs2 | rs1 | 010 | rd | 0110011

u32 R\_sltu; // 0000000 | rs2 | rs1 | 011 | rd | 0110011

u32 R\_xor; // 0000000 | rs2 | rs1 | 100 | rd | 0110011

u32 R\_srl; // 0000000 | rs2 | rs1 | 101 | rd | 0110011

u32 R\_sra; // 0100000 | rs2 | rs1 | 101 | rd | 0110011

u32 R\_or; // 0000000 | rs2 | rs1 | 110 | rd | 0110011

u32 R\_and; // 0000000 | rs2 | rs1 | 111 | rd | 0110011

u32 I\_fence; // 0000 | pred | succ |00000| 000 | 00000 | 0001111

u32 I\_fence.i; // 0000 | 0000 | 0000 |00000| 001 | 00000 | 0001111

u32 I\_ecall; // 000000000000 | 00000| 000 | 00000 | 1110011

u32 I\_ebreak; // 000000000001 | 00000 | 000 | 00000 | 1110011

u32 I\_csrrw; // csr | rs1 | 001 | rd | 1110011

u32 I\_csrrs; // csr | rs1 | 010 | rd | 1110011

u32 I\_csrrc; // csr | rs1 | 011 | rd | 1110011

u32 I\_csrrwi; // csr | zimm | 101 | rd | 1110011

u32 I\_csrrsi; // csr | zimm | 110 | rd | 1110011

u32 I\_csrrci; // csr | zimm | 111 | rd | 1110011

};

RV32M\_Opcode\_Map {

u32 R\_mul; // 0000001 | rs2 | rs1 | 000 | rd | 0110011

u32 R\_mulh; // 0000001 | rs2 | rs1 | 001 | rd | 0110011

u32 R\_mulhsu; // 0000001 | rs2 | rs1 | 010 | rd | 0110011

u32 R\_mulhu; // 0000001 | rs2 | rs1 | 011 | rd | 0110011

u32 R\_div; // 0000001 | rs2 | rs1 | 100 | rd | 0110011

u32 R\_divu; // 0000001 | rs2 | rs1 | 101 | rd | 0110011

u32 R\_rem; // 0000001 | rs2 | rs1 | 110 | rd | 0110011

u32 R\_remu; // 0000001 | rs2 | rs1 | 111 | rd | 0110011

}

RV32F\_Opcode\_Map {

u32 I\_flw; //

u32 S\_fsw; //

u32 R4\_fmadd.s; //

u32 R4\_fmsub.s; //

u32 R4\_fnmsub.s; //

u32 R4\_fnmadd.s; //

u32 R\_fadd.s; //

u32 R\_fsub.s; //

u32 R\_fmul.s; //

u32 R\_fdiv.s; //

u32 R\_fsqrt.s; //

u32 R\_fsgnj.s; //

u32 R\_fsgnjn.s; //

u32 R\_fsgnjx.s; //

u32 R\_fmin.s; //

u32 R\_fmax.s; //

u32 R\_fcvt.w.s; //

u32 R\_fcvt.wu.s; //

u32 R\_fmv.x.w; //

u32 R\_feq.s; //

u32 R\_flt.s; //

u32 R\_fle.s; //

u32 R\_fclass.s; //

u32 R\_fvct.s.w; //

u32 R\_fvct.s.wu; //

u32 R\_fmv.w.x; //

}

RV32D\_Opcode\_Map {

u32 I\_fld; //

u32 S\_fsd; //

u32 R4\_fmadd.d; //

u32 R4\_fmsub.d; //

u32 R4\_fnmsub.d; //

u32 R4\_fnmadd.d; //

u32 R\_fadd.d; //

u32 R\_fsub.d; //

u32 R\_fmul.d; //

u32 R\_fdiv.d; //

u32 R\_fsqrt.d; //

u32 R\_fsgnj.d; //

u32 R\_fsgnjn.d; //

u32 R\_fsgnjx.d; //

u32 R\_fmin.d; //

u32 R\_fmax.d; //

u32 R\_fcvt.s.d; //

u32 R\_fcvt.d.s; //

u32 R\_feq.d; //

u32 R\_flt.d; //

u32 R\_fle.d; //

u32 R\_fclass.d; //

u32 R\_fcvt.w.d; //

u32 R\_fvct.s.wu.d; //

u32 R\_fvct.d.w; //

u32 R\_fvct.d.wu; //

}

|  |  |  |
| --- | --- | --- |
|  | f0 / ft0 | FP Temporary |
|  | f1 / ft0 | FP Temporary |
|  | f2 / ft0 | FP Temporary |
|  | f3 / ft0 | FP Temporary |
|  | f4 / ft0 | FP Temporary |
|  | f5 / ft0 | FP Temporary |
|  | f6 / ft0 | FP Temporary |
|  | f7 / ft0 | FP Temporary |
|  | f8 / ft0 | FP Saved register |
|  | f9 / ft0 | FP Saved register |
|  | f10 / ft0 | FP Function argument, return value |
|  | f11 / ft0 | FP Function argument, return value |
|  | f12 / ft0 | FP Function argument |
|  | f13 / ft0 | FP Function argument |
|  | f14 / ft0 | FP Function argument |
|  | f15 / ft0 | FP Function argument |
|  | f16 / ft0 | FP Function argument |
|  | f17 / ft0 | FP Function argument |
|  | f18 / ft0 | FP Saved register |
|  | f19 / ft0 | FP Saved register |
|  | f20 / ft0 | FP Saved register |
|  | f22 / ft0 | FP Saved register |
|  | f23 / ft0 | FP Saved register |
|  | f24 / ft0 | FP Saved register |
|  | f25 / ft0 | FP Saved register |
|  | f26 / ft0 | FP Saved register |
|  | f27 / ft0 | FP Saved register |
|  | f28 / ft0 | FP Temporary |
|  | f29 / ft0 | FP Temporary |
|  | f30 / ft0 | FP Temporary |
|  | f31 / ft0 | FP Temporary |

The floating-point registers of RV32F and RV32D.

RV32A\_Opcode\_Map {

u32 R\_1r.w; //

u32 R\_sc.w; //

u32 R\_amoswap.w; //

u32 R\_amoadd.w; //

u32 R\_amoxor.w; //

u32 R\_amoand.w; //

u32 R\_amoxor.w; //

u32 R\_amoand.w; //

u32 R\_amoor.w; //

u32 R\_amomin.w; //

u32 R\_amomax.w; //

u32 R\_amominu.w; //

u32 R\_amomax.w; //

}

|  |  |  |
| --- | --- | --- |
| U-type for long immediate | U\_lui | U-type long upper immediate |
| Does U imply Unsigned? | U\_auipc | U-type add upper immediate to pc |
|  | U\_jal | U-type jump and link |
|  | U\_jalr | U-type jump and link register |
| B-type for conditional branches | B\_beq | B-type branch equal |
| Does B imply Branch? | B\_bne | B-type branch not equal |
|  | B\_blt | B-type branch less than |
|  | B\_bge | B-type greater than or equal |
|  | B\_bltu | B-type branch less than unsigned |
|  | B\_bgeu | B-type greater than or equal unsigned |
| I-type for short immediate | I\_lb | I-type load byte |
| Does I imply Immediate? | I\_lh | I-type load halfword |
| \_l - load | I\_lw | I-type load word |
|  | I\_lbu | I-type load byte unsigned |
|  | I\_lhu | I-type load halfword unsigned |
| S-type instruction is for Store | S\_sb | S-type store byte |
| Does S imply Store? | S\_sh | S-type store halfword |
|  | S\_sw | S-type word |
| I-type for short immediate | I\_addi | I-type add immediate |
| Does I imply Immediate? | I\_slti | I-type set less than immediate |
|  | I\_sltiu | I-type set less than immediate unsigned |
|  | I\_xori | I-type exclusive or immediate |
|  | I\_ori | I-type or immediate |
|  | I\_andi | I-type and immediate |
|  | I\_slli | I-type shift left logical immediate |
|  | I\_srli | I-type shift right logical immediate |
|  | I\_srai | I-type shift right arithmetic immediate |
| R-type for register-register operation | R\_add | R-type add |
| Does R imply register? | R\_sub | R-type subtract |
|  | R\_sll | R-type shift left logical |
|  | R\_slt | R-type set less than |
|  | R\_sltu | R-type set less then unsigned |
|  | R\_xor | R-type exclusive or |
|  | R\_srl | R-type shift right logical |
|  | R\_sra | R-type shift right arithmetic |
|  | R\_or | R-types or |
|  | R\_and | R-type and |
| I-type for short immediate | I\_fence | I-type fence loads & stores |
| Does I imply immediate? | I\_fence.i | I-type instruction & data |
|  | I\_ecall | I-type environment call |
|  | I\_ebreak | I-type environment break |
|  | I\_csrrw | I-type control status register read & write |
|  | I\_csrrs | I-type control status register read & set bit |
|  | I\_csrrc | I-type control status register read & clear bit |
|  | I\_csrrwi | I-type control status register read & write immediate |
|  | I\_csrrsi | I-type control status register read & set bit immediate |
|  | I\_csrrci | I-type control status register read & clear bit immediate |

0

31

|  |  |
| --- | --- |
| x0 / zero | Hardwired zero |
| x1 / ra | Return address |
| x2 / sp | Stack pointer |
| x3 / gp | Global pointer |
| x4 / tp | Thread pointer |
| x5 / t0 | Temporary |
| x6 / t1 | Temporary |
| x7 / t2 | Temporary |
| x8 / s0 / fp | Saved register, frame pointer |
| x9 / s1 | Saved register |
| x10 / a0 | Function argument, return value |
| x11 / a1 | Function argument, return value |
| x12 / a2 | Function argument |
| x13 / a3 | Function argument |
| x14 / a4 | Function argument |
| x15 / a5 | Function argument |
| x16 / a6 | Function argument |
| x17 / a7 | Function argument |
| x18 / s2 | Saved register |
| x19 / s3 | Saved register |
| x20 / s4 | Saved register |
| x21 / s5 | Saved register |
| x22 / s6 | Saved register |
| x23 / s7 | Saved register |
| x24 / s8 | Saved register |
| x25 / s9 | Saved register |
| x26/ s10 | Saved register |
| x27 /s11 | Saved register |
| x28 / t3 | Temporary |
| x29 / t4 | Temporary |
| x30 / t5 | Temporary |
| x31 / t6 | Temporary |

32

31

0

|  |
| --- |
| PC |

32

References:

1. ARMSim: An Instruction-Set Simulator for the ARM processor, Alpa Shah, Columbia University
2. Flexible Timing Simulation of RISC-V Processors with Sniper, Neethu Bal Mallya, Cecilia Gonzalez-Alvarez, Trevor E. Carlson, CARRV 2018, June 2018
3. Fast, Accurate, and Validated Full-System Software Simulation of x86 Hardware, Frederick Ryckbosch, Stijn Polfliet, Lieven Eeckhout, Ghent University, IEEE Computer Society, 2010.
4. ARMISS: An Instruction Set Simulator for the ARM Architecture, Mingsong Lv, Qingxu Deng, Nan Guan, Yaming Xie, Ge Yu, Institute of Computer Software and Theory, Northeastern University
5. ISA Semantics for ARMv8-A, RISC-V, and CHERI-MIPS, Alasdair Armstrong, University of Cambridge, UK, et. al., January 2019.
6. SHAKTI: An Open-Source Processor Ecosystem, Neel Gala, G.S.Madhusudan, InCore Semiconductors Pvt. Ltd., Paul George, Anmore Sahoo, Arjun Menon, V. Kamakoti, Indian Institute of Technology, Madras, Advanced Computing & Communications, Processor Ecosystem, Volume 02 Issue 03 September 2018.
7. Extensible and Configurable RISC-V based Virtual Prototype, Vladimir Herdt, Daniel GroBe, Hoang M. Le, Rolf Drechsler, Institute of Computer Science, University of Bremen; Cyber-Physical Systems, DFKI GmbH, Bremen, Germany.
8. RISC5: Implementing the RISC-V ISA in gem5, Alec Roelke, Mircea R. Stan; University of Virginia.
9. Full-System Simulation of Java Workloads with RISC-V and the Jikes Research Virtual Machine, Martin Maas, Krste Asanovic, John Kubiatowicz, University of California, Berkeley
10. The RISC-V Reader – An Open Architecture Atlas, First Edition, 1.0.0, David Patterson, Andrew Waterman, November 7, 2017
11. Implementation of Direct Segments of a RISC-V Processors, Nikhita Kunati, Michael M. Switch
12. The Rust Programming Language, Steve Klabnik and Carlo Nichols with contributions from the Rust Community, no scratch press, San Francisco, CA.
13. Mastering Qt 5, Packet Publishing, December 2016.
14. <https://riscv.org/software-tools/risc-v-gnu-compiler-toolchain/> (Tools)
15. Spike – <https://github.com/riscv/riscv-isa-sim>
16. Computer Architecture, A Quantitative Approach, Sixth Edition, John L. Hennessy & David Paterson

**Paper Notes:**

1. **ARMSim: An Instruction-Set Simulator for the ARM processor (First Pass -** Done**)**
2. **Flexible Timing Simulation of RISC-V Processors with Sniper (First Pass -** Done**)**
3. **FAST, ACCURATE, and Validated Full-System Software Simulation of x86 Hardware (First Pass** – Done**)**
4. **ARMISS: An Instruction Set Simulator for the ARM Architecture (First Pass** - Done**)**
5. **ISA Semantics for ARMv8-A, RISC-V, and CHRI-MIPS (First Pass** – Done**)**
6. **Extensible and Configurable RISC-V based Virtual Prototype (First Pass** - Done**)**
7. **RISC5: Implementing the RISC-V ISA in gem5 (First Pass** - Done**)**
8. **Implementation of Direct Segments on a RISC-V Processor (First Pass** – Done**)**
9. **Full-System Simulation of Java Workloads with RISC-V and the Jikes Research Virtual Machine (First Pass** - Done**)**

**TBD/Open Issues** –

1. **Implementation Notes** - Diagrams for simulator execution and data flows.
2. **Implementation Notes** - Diagrams-block level to microarchitecture to software modules and processes (in Rust).
3. **Implementation Idea** - OPCODE interpretation optimizations techniques.
4. Features: {

**What does it mean to be accurate?**

**What does it mean to support speed?**

**What does it mean to have options?**

Option Family 1: Performance family options could mean varying cache and register file sizes and instantiating subcomponents (co-processors) and memory hierarchy.}

1. **Implementation Idea** - How about SaaS Model for the simulator?
2. **Implementation Idea** - How would you run time control this simulator, purely from GUI or would there be CLI? Would it be better to have a Python-based control embedded with the simulator module?
3. **Architecture Specific Question** – Are there co-processors - Functional Units standard across all cores and class of processors (RISC-V).
4. **Implementation Question** - What defines the state of the system? What all the processor subcomponents be inclusive in defining the state of the system?
5. **Implementation Question** - How will memory hierarchy be modeled? How will the delay statics be modeled? How will the instruction memory be stored?
6. **Implementation Question** – What all data transfer sizes will be supported?
7. **Implementation Question** - What is the cycle of instruction in RISC-V?
8. **Implementation Question** - Is it necessary in the ISS – behavioral model - to have cache warming mode for ROI (Region of Interest)? Do we need to look at ROI versus non-ROI regions?
9. **Implementation Question** - Where all would the trace files be created and their formats?
10. **Implementation Question** - Is design space exploration a requirement for this simulator?
11. **Implementation Question** – What are the realization specific micro architectural implications on this ISA?
12. **Implementation Question** - Processor State and Statistics Gathering, what and how?
13. **Design consideration** – How would a multi-threaded model of the program look like? Number of Machine involved?
14. **Goal Statement**: Primary applications for simulators consist of computer architecture studies and performance tuning of compiled software and the compilation process itself.
15. **Implementation Ideas** – Are we to implement dynamic binary translation (to x86\_64) techniques?
16. **Implementation Ideas** - How much detail is enough to model a processor?
17. **Implementation Questions** – What are the interfaces of this ISA that to be plugged into standard buses and memory interfaces?
18. **Implementation Question** –Interrupt handling and system calls (environment interaction), how?
19. **Implementation Question** – How do we address the issue of generating data for power and timing?
20. **Implementation Question** – How would the details of interrupt handling and system calls – interaction sequence as described by the code look like? (Software Side Code and the Model side itself).
21. **Implementation Question** – How would the debugger such as GDB work on the simulator?
22. **Implementation Question** – How do we model memory interactions? Even if these were simply to account for timing and integrity of sequence of execution.
23. **Implementation Question** –How will the issue of compact switching be impacted/addressed, this for the simulator?
24. **Implementation Question** – How does our implementation address the issues of bottlenecks in simulating the CPU core? Does this issue of multi-threading concern Behavioral Modeling?
25. **Implementation Note** – RISC-V follows the *release consistency* memory model.
26. **Implementation Note** – RISC-V follows IEEE-754 2008 floating-point standard. Simulator implementation will be targeted to confirm to the specification.
27. **Implementation Note** – How do we address different simulation paradigms high-level architectural and memory models, and advanced simulation features? Balancing achieving of high accuracy with reduced simulation time.
28. **Implementation Question** – Will implement system call emulation (SE) mode that will replace program’s own system calls with ones on/to the host?
29. **Implementation Question –** How are the checkpoint saved and used to resume the simulation?
30. **Implementation Question –** Will implementation support features and techniques such as phase analysis? Implications?
31. **Implementation Question** – What all are the data sets that will need to be generated to feed as input to external tools so that we can get estimations such as power, temperature, voltage noise etc.? Is some of these tabulated so the we can embed in Behavioral Model.
32. **Implementation Question** – What all are the test programs we should be executing to test the Behavioral Model and development tools setup/flow?
33. **Implementation Question** – How do we separate microarchitecture implementation form the general-purpose functions allowing adaption of simulator for different classes of processors?
34. **Implementation Question** – How does a simulator such as this help support the need for hardware-software co-design? RISC-V is an open source ISA and can be implemented on an FPGAs for full-system simulation that can yield better results.
35. **Implementation Question** – Particularly for managed-language research how do you achieve realism, fidelity and simulation speed required to simulate managed-language workloads. Can we port something like JikesRVM to this simulator? Are FPGA based simulators better for these sorts of research?
36. **Implementation Question** – Should we be targeting to use test-suites by RISC-V Compliance Working Group?
37. **Implementation Question** – Should we have comparable output as with Spike or other simulators? Should we look to compare trace files?
38. **Implementation Question** – What sort of test tools should we look forward to integrating with the simulator?
39. **Implementation Comment** - Along with behavioral aspects entailing instruction set, hardware-software interfacing, simulator could also look at the concurrency mode and interrupt behavior.
40. **Implementation Question** – What are the CPU performance benchmarking programs we should support to bring out any deficiency in implementation?
41. **Implementation Question** – How would we test the entire software stack particularly entailing network card, disk drive etc.?
42. **Implementation Question** – How would we simulate multicore processors?
43. **Implementation Question** – How do we handle disruptive miss events?
44. **Implementation Question** – Are there any implications of interval simulation/analysis technique or aspects of the same on the simulator we are developing?
45. **Implementation Question** – What kind of disruptive miss events circumventing solutions modeling we intend to support with this simulator?
46. **Implementation Question** – GUI screen shots and terminal - showing the possible set of control commands for the simulator.

1. Instruction set simulator [ISS] execute target machine programs by simulating the effects of each instruction on a target machine, one instruction at a time. [↑](#footnote-ref-1)
2. Reasonable speed of execution as supported by the underlying hardware. [↑](#footnote-ref-2)